package top.lshaci.learning.interview.jvm.oom;

import java.util.ArrayList;
import java.util.List;

/**
 * GC回收时间长时会抛出OutOfMemoryError。
 * 过长的定义是，
 * 超过98%的时间用来做GC并且回收了不到2%的堆内存，
 * 连续多次GC都只回收了不到2%的极端情况下才会抛出。
 * <p>
 * 假设不抛出GC overhead limit错误会发生什么情况呢？
 * 那就是GC清理的这么点内存很快会再次填满，迫使GC再次执行，这样就形成恶性循环，CPU使用率一直
 * 是100%，而GC缺没有任何成果。
 */
public class GCOverheadDemo {

    /**
     * -Xms10m -Xmx10m -XX:+PrintGCDetails -XX:MaxDirectMemorySize=5m
     */
    public static void main(String[] args) {
        int i = 0;
        List<String> list = new ArrayList<>();

        try {
            while (true) {
                list.add(String.valueOf(++i).intern());
            }
        } catch (Throwable e) {
            System.out.println("***************i:" + i);
            e.printStackTrace(); // java.lang.OutOfMemoryError: GC overhead limit exceeded
            throw e;
        }

    }
}
